#include <iostream>
#include <queue>
#include <map>
#include <unordered_map>
#include <vector>
#include <algorithm>
#include <cmath>
#include <string>
#include <cstring>
#include <set>
#include <unordered_set>
#define IOS ios::sync_with_stdio(false), cin.tie(0), cout.tie(0)
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
typedef pair<int,int> pii;
int main()
{
	int t;
	cin>>t;
	while(t--)
	{
		int n,k;
		cin>>n>>k;
		int a=0;
		int b=0;
		int sum=0;
		for(int i=0;i<=n;i++)
		{
			int a1=i;
			int b1=n-i;
			if(a1*(a1-1)/2+(b1-1)*b1/2==k)
			{
				a=a1;
				b=b1;
				break; 
			}
		}
		if(a!=0 || b!=0)
		{
			cout<<"YES"<<endl;
			for(int i=0;i<a;i++) cout<<1<<' ';
			for(int i=0;i<b;i++) cout<<-1<<' ';
			cout<<endl;
		}
		else cout<<"NO"<<endl;
	}

	return 0;
}

